/* 代码高亮样式 */

/* 亮色主题代码高亮 */
:root {
  .hljs {
    background: #f8f8f8 !important;
    color: #333 !important;
    border-radius: 6px;
    padding: 16px;
    font-family: 'Fira Code', 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
    font-size: 14px;
    line-height: 1.5;
    overflow-x: auto;
    
    /* 关键字 */
    .hljs-keyword,
    .hljs-selector-tag,
    .hljs-literal,
    .hljs-section,
    .hljs-link {
      color: #d73a49 !important;
      font-weight: 600;
    }
    
    /* 字符串 */
    .hljs-string,
    .hljs-attr {
      color: #032f62 !important;
    }
    
    /* 注释 */
    .hljs-comment,
    .hljs-quote,
    .hljs-meta {
      color: #6a737d !important;
      font-style: italic;
    }
    
    /* 数字 */
    .hljs-number,
    .hljs-regexp {
      color: #005cc5 !important;
    }
    
    /* 函数名 */
    .hljs-title,
    .hljs-function .hljs-title {
      color: #6f42c1 !important;
      font-weight: 600;
    }
    
    /* 变量 */
    .hljs-variable,
    .hljs-name {
      color: #e36209 !important;
    }
    
    /* 类型 */
    .hljs-type,
    .hljs-class .hljs-title {
      color: #d73a49 !important;
    }
    
    /* 属性 */
    .hljs-attribute,
    .hljs-property {
      color: #005cc5 !important;
    }
  }
}

/* 暗色主题代码高亮 */
[data-theme="dark"] {
  .hljs {
    background: #282c34 !important;
    color: #abb2bf !important;
    
    /* 关键字 */
    .hljs-keyword,
    .hljs-selector-tag,
    .hljs-literal,
    .hljs-section,
    .hljs-link {
      color: #c678dd !important;
      font-weight: 600;
    }
    
    /* 字符串 */
    .hljs-string,
    .hljs-attr {
      color: #98c379 !important;
    }
    
    /* 注释 */
    .hljs-comment,
    .hljs-quote,
    .hljs-meta {
      color: #5c6370 !important;
      font-style: italic;
    }
    
    /* 数字 */
    .hljs-number,
    .hljs-regexp {
      color: #d19a66 !important;
    }
    
    /* 函数名 */
    .hljs-title,
    .hljs-function .hljs-title {
      color: #61afef !important;
      font-weight: 600;
    }
    
    /* 变量 */
    .hljs-variable,
    .hljs-name {
      color: #e06c75 !important;
    }
    
    /* 类型 */
    .hljs-type,
    .hljs-class .hljs-title {
      color: #e5c07b !important;
    }
    
    /* 属性 */
    .hljs-attribute,
    .hljs-property {
      color: #56b6c2 !important;
    }
  }
}

/* 代码块容器样式 */
pre {
  position: relative;
  margin: 16px 0;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  
  code {
    display: block;
    padding: 0;
    background: transparent !important;
    border-radius: 0;
  }
  
  /* 语言标签 */
  &::before {
    content: attr(data-language);
    position: absolute;
    top: 8px;
    right: 12px;
    font-size: 12px;
    color: #666;
    background: rgba(255, 255, 255, 0.8);
    padding: 2px 6px;
    border-radius: 3px;
    font-family: 'Monaco', 'Menlo', monospace;
    z-index: 1;
  }
}

[data-theme="dark"] pre::before {
  color: #ccc;
  background: rgba(0, 0, 0, 0.3);
}

/* 行内代码样式 */
code:not(.hljs) {
  background: #f1f3f4;
  color: #d73a49;
  padding: 2px 4px;
  border-radius: 3px;
  font-family: 'Fira Code', 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
  font-size: 0.9em;
}

[data-theme="dark"] code:not(.hljs) {
  background: #3c4043;
  color: #f8ce7b;
}

/* 复制按钮样式 */
.code-copy-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  background: rgba(255, 255, 255, 0.8);
  border: none;
  border-radius: 4px;
  padding: 4px 8px;
  font-size: 12px;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.2s;
  z-index: 2;
  
  &:hover {
    background: rgba(255, 255, 255, 0.9);
  }
}

[data-theme="dark"] .code-copy-btn {
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  
  &:hover {
    background: rgba(0, 0, 0, 0.8);
  }
}

pre:hover .code-copy-btn {
  opacity: 1;
}